#### (19) 世界知的所有権機関 国際事務局



# 

(43) 国際公開日 2004年7月29日(29.07.2004)

PCT

(10) 国際公開番号 WO 2004/063925 A1

(51) 国際特許分類7:

G06F 9/46

(21) 国際出願番号:

PCT/JP2003/015838

(22) 国際出願日:

2003年12月11日(11.12.2003)

(25) 国際出願の言語:

日本語

(26) 国際公開の言語:

日本語

(30) 優先権データ:

2003年1月9日 (09.01.2003) 特願2003-3038

(71) 出願人(米国を除く全ての指定国について): 独立 行政法人科学技術振興機構 (JAPAN SCIENCE AND TECHNOLOGY AGENCY) [JP/JP]; 〒332-0012 埼玉 県川口市本町4-1-8 Saitama (JP).

(72) 発明者; および

(75) 発明者/出願人 (米国についてのみ): 山崎 信行 (YA-MASAKI,Nobuyuki) [JP/JP]; 〒221-0802 神奈川県 横 浜市 神奈川区六角橋 2-2 1-4 Kanagawa (JP).

(74) 代理人: 橋爪 健 (HASHIZUME, Takeshi); 〒104-0061 東京都中央区銀座3丁目13番17号 Tokyo (JP).

(81) 指定国 (国内): US.

(84) 指定国 (広域): ヨーロッパ特許 (DE, FR, GB, NL).

添付公開書類:

国際調査報告書

2文字コード及び他の略語については、 定期発行される 各PCTガゼットの巻頭に掲載されている「コードと略語 のガイダンスノート」を参照。

(54) Title: CONTEXT SWITCHING METHOD, DEVICE, PROGRAM, RECORDING MEDIUM, AND CENTRAL PROCESS-**ING UNIT** 

(54) 発明の名称: コンテキスト切り替え方法・装置・プログラム・記憶媒体、中央演算装置



8...CONTEXT CACHE 1...REGISTER FILE
2...INSTRUCTION FETCH UNIT
3...INSTRUCTION CACHE
9...THREAD CONTROL UNIT 5...MEMORY ACCESS UNIT 6...DATA CACHE 7...BUS INTERFACE UNIT 20...MEMORY

- (57) Abstract: In an application in which context switching often occurs such as in a real time OS, it is possible to significantly reduce the overhead caused by the context switching. The OS issues a Swap instruction and a context switch starts. The Swap instruction is issued together with a thread (i.e., context) ID to be replaced, to a thread control unit (9). The thread ID is used to uniquely identify threads stored in a context cache (8). The thread control unit (9) saves data from a register file (1) to the context cache (8) via a context-dedicated bus (12) and transmits data of a new thread from the context cache (8) to the register file (1). According to the thread ID received, the thread control unit (9) automatically interchanges the necessary number of data in the register file (1) and the data in the context cache (8).
- (57) 要約: リアルタイムOSなどコンテキストの切り替えが頻 繁に発生するアプリケーションにおいて、コンテキストの切り替 えによるオーバーヘッドを大幅に削減する。 OSIL, Swap 命令を発行し、コンテキストスイッチが開始する。Swap命令 は、入れ替えるスレッドIDと共にスレッド制御ユニット9に 発行される。スレッドIDは、コンテキストキャッシュ8に格 納されているスレッドを一意に識別するために用いる。スレッ ド制御ユニット9は、コンテキスト専用バス12を経て、レジ スタファイル 1 からコンテキストキャッシュ 8 ヘデータを退避 すると同時に、コンテキストキャッシュ8からレジスタファイ ル1へ新しいスレッドのデータを送る。スレッド制御ユニット 9は、送られてきたスレッドIDに基づいて自動的に必要な数 だけレジスタファイル 1 内のデータとコンテキストキャッシュ 8内のデータを入れ替える。

# 明細書

コンテキスト切り替え方法・装置・プログラム・記憶媒体、中央演算装置

5

10

15

20

25

### 技術分野

本発明は、コンテキスト切り替え方法及び装置、中央演算装置、コンテキスト切り替えプログラム及びそれを記憶したコンピュータ読み取り可能な記憶媒体に係り、特に、リアルタイム・オペレーティングシステム(RT-OS)等のOSにおいてコンテキストの切り替えによるオーバーヘッドの削減を可能にするコンテキスト切り替え方法及び装置、中央演算装置、コンテキスト切り替えプログラム及びそれを記憶したコンピュータ読み取り可能な記憶媒体に関する。ここで、コンテキストとは、例えば、汎用レジスタ、浮動小数点レジスタ、プログラムカウンタ、ステータスレジスタ等、記憶部(例、レジスタファイル)に記憶されている各スレッドの実行のための情報又は現在実行中の状態のことをいう。

## 背景技術

図8に、コンテキスト切り替え動作の説明図を示す。

この図では、複数のコンテキスト(スレッド)が1つの中央演算装置で切り替えられて実行されている例を示している。コンテキストが切り替わる場合、今まで実行していたコンテキストの状態(汎用レジスタ、浮動小数点レジスタ、プログラムカウンタ、ステータスレジスタなどであり、以下、単にコンテキストという場合がある。)を保存し、新しく実行するコンテキストの状態を読み出す必要がある。切り替え動作の際に要する時間をオーバーヘッドといい、オーバーヘッドは、コンテキストが切り替わる度に発生する。

従来、コンテキスト切り替え時間を短縮するための技術としては、以下の文献が 挙げられる。

特許文献1(特開平07-141208号)には、リアルタイムオペレーティングシス

テムを用いたマルチタスク処理装置において、各タスクに対応して占有される複数のレジスタバンクを設け、コンテキスト等の退避/復帰がレジスタバンクを切り替えることにより行い、ディスパッチ時間を短縮する技術が記載されている。

また、特許文献2(特開平09-212371号)には、マルチタスク処理を行うマイクロプロセッサにおいて、複数のレジスタに対応してその内容の変化又は非変化を示すビットを設け、タスク切り替えが発生したときに、そのビットに従い、レジスタの内容が変化したときに退避命令を実行し、変化しないとき退避命令を実行しないようにすることで、OSのオーバーヘッドを減少させるレジスタ退避及び復元システムが記載されている。

10

15

20

25

5

### 発明の開示

従来の方法では、コンテキストを切り替える場合、中央演算装置内に保持されているコンテキストの状態は、OS等のソフトウェアによりストア命令を用いて1つずつ中央演算装置外の記憶装置に保存される。その後、OS等のソフトウェアは、ロード命令を用いて新しいコンテキストを記憶装置から読み込む。つまり、コンテキストを切り替える度に、コンテキストの保存と読み込みのためのメモリアクセスが数百サイクルから千数百サイクルも生じることになり、大きなオーバーヘッドとなっている。また、従来の方法では、ロード命令やストア命令を用いたソフトウェアによるコンテキストの保存と読み込みを行っているため、1度に1つのデータしか扱うことができない。そのため保存すべき状態が増えるとコンテキストスイッチにかかる時間も増加する。

本発明は、以上の点に鑑み、特に、リアルタイムOSなどコンテキストの切り替えが頻繁に発生するアプリケーションにおいて、コンテキストの切り替え(コンテキストスイッチ)によるオーバーヘッドを大幅に削減することを目的とする。本発明は、例えば、コンテキストを切り替える度に、コンテキストの保存と読み込みのためのメモリアクセスが、1サイクルから数サイクルで可能とするコンテキスト切り替え方法及び装置、中央演算装置、コンテキスト切り替えプログラム及びそれを記憶したコンピュータ読み取り可能な記憶媒体を提供することを目的とする。

また、本発明は、特に実時間処理システムのようにコンテキストスイッチが頻繁

に起こるシステムにおいて、コンテキストスイッチにかかる時間を一定とし、実時間性の時間粒度を非常に小さくすることを目的とする。

本発明は、特に、

- 1. コンテキストを保持するための専用記憶装置(コンテキストキャッシュ)を持 5 ち、
  - 2. レジスタよりビット幅の広い専用バスを用いて専用記憶装置(コンテキストキャッシュ)と中央演算装置(CPU)を接続する、

ことにより、コンテキスト切り替えにかかるオーバーヘッドを削減する。

本発明の第1の解決手段によると、

10 複数のコンテキストを切り替えるコンテキスト切り替え装置であって、

演算論理ユニット又はメモリアクセスユニットで実行すべきスレッドに関するコンテキストが記憶されたレジスタファイルと、

前記レジスタファイルに接続され、コンテキストをキャッシュするためのコンテキストキャッシュと、

15 前記レジスタファイルと前記コンテキストキャッシュを接続するコンテキストスイッ チ専用バスと、

前記コンテキストキャッシュに記憶されているスレッドのコンテキストを識別するためのスレッド識別子(スレッドID)を記憶するスレッドIDテーブルを有し、演算論理ユニット及びメモリアクセスユニットと並列に接続され、前記コンテキストキャッシュと前記レジスタファイルとの間のコンテキストのデータ転送を制御するスレッド制御ユニットと

を備え、

20

前記スレッド制御ユニットは、

コンテキストの切り替えが発生した場合、入力された切り替え命令と新たに入れ 25 替えるスレッド識別子(スレッドID)に基付き前記スレッドIDテーブルを検索し、

新たに入れ替えるコンテキストが記憶されている前記コンテキストキャッシュのアドレスと、実行中のコンテキストが記憶されている前記レジスタファイルのレジスタ識別子を求め、

求めたアドレスに基付き前記コンテキストキャッシュをアクセスし、且つ、求めた

レジスタ識別子に基付き前記レジスタファイルをアクセスし、前記レジスタファイル 及び/又は前記コンテキストキャッシュのコンテキストを前記コンテキストスイッチ 専用バスを介して入れ替え、退避又は復帰を実行する

前記コンテキスト切り替え装置

5 が提供される。

本発明の第2の解決手段によると、

上述のようなコンテキスト切り替え装置と、

命令及びデータをそれぞれキャッシュする命令キャッシュ及びデータキャッシュ と、

10 前記命令キャッシュから命令をフェッチ及びデコードする命令フェッチユニットと、 レジスタファイルに記憶された命令に従い各種演算を行い、演算結果を前記レ ジスタファイルに書き戻す演算論理ユニットと、

前記レジスタファイルからオペランドと命令が送られ、前記データキャッシュをアクセスし、ロード又はストアを実行するメモリアクセスユニットと、

15 前記レジスタファイル、前記演算論理ユニット、前記メモリアクセスユニット及び前 記スレッド制御ユニットを並列に接続する演算バスと、

を備えた中央演算装置

が提供される。

本発明の第3の解決手段によると、

20 演算論理ユニット又はメモリアクセスユニットで実行すべきスレッドに関するコン テキストが記憶されたレジスタファイルと

前記レジスタファイルに接続され、コンテキストをキャッシュするためのコンテキストキャッシュと、

を備えたコンテキスト切り替え装置を用い、複数のコンテキストを切り替えるコンテキスト切り替え方法であって、

コンテキストの切り替えが発生した場合、入力された切り替え命令と新たに入れ替えるスレッド識別子(スレッドID)に基付き、前記コンテキストキャッシュに記憶さ

25

れているスレッドのコンテキストを識別するためのスレッド識別子(スレッドID)を記憶する前記スレッドIDテーブルを検索し、

新たに入れ替えるコンテキストが記憶されている前記コンテキストキャッシュのアドレスと、実行中のコンテキストが記憶されている前記レジスタファイルのレジスタ識別子を求め、

求めたアドレスに基付き前記コンテキストキャッシュをアクセスし、且つ、求めたレジスタ識別子に基付き前記レジスタファイルをアクセスし、前記レジスタファイル及び/又は前記コンテキストキャッシュのコンテキストを前記コンテキストスイッチ専用バスを介して入れ替え、退避又は復帰を実行する

10 前記コンテキスト切り替え方法

が提供される。

さらに、本発明の第4の解決手段によると、

演算論理ユニット又はメモリアクセスユニットで実行すべきスレッドに関するコンテキストが記憶されたレジスタファイルと、

15 前記レジスタファイルに接続され、コンテキストをキャッシュするためのコンテキ ストキャッシュと、

前記レジスタファイルと前記コンテキストキャッシュを接続するコンテキストスイッチ専用バスと

を備えたコンテキスト切り替え装置を用い、コンピュータが複数のコンテキストを切 20 り替えるコンテキスト切り替えプログラムを記録したコンピュータ読み取り可能な 記録媒体であって、

コンテキストの切り替えが発生した場合、入力された切り替え命令と新たに入れ替えるスレッド識別子(スレッドID)に基付き、前記コンテキストキャッシュに格納されているスレッドのコンテキストを識別するためのスレッド識別子(スレッドID)を記憶する前記スレッドIDテーブルを検索するステップと、

新たに入れ替えるコンテキストが記憶されている前記コンテキストキャッシュの アドレスと、実行中のコンテキストが記憶されている前記レジスタファイルのレジス タ識別子を求めるステップと、

求めたアドレスに基付き前記コンテキストキャッシュをアクセスし、且つ、求めた

レジスタ識別子に基付き前記レジスタファイルをアクセスし、前記レジスタファイル 及び/又は前記コンテキストキャッシュのコンテキストを前記コンテキストスイッチ 専用バスを介して入れ替え、退避又は復帰を実行するステップと をコンピュータに実行させるためのコンテキスト切り替えプログラム、及び、そのプログラムを記録したコンピュータ読み取り可能な記録媒体 が提供される。

## 図面の簡単な説明

第1図は、一般的なCPUを含むコンピュータの構成図である。

10 第2図は、一般的なCPUでのコンテキストスイッチのフローチャートである。 第3図は、コンテキストキャッシュを用いたCPUを含むコンピュータの構成図で ある。

第4図は、コンテキストキャッシュを用いたCPUでのコンテキストスイッチのフローチャートである。

15 第5図は、コンテキスト切り替え装置の詳細構成図である。

第6図は、Swap命令のフローチャートである。

第7図は、コンテキスト切り替え装置の実装に関する説明図である。

第8図は、コンテキスト切り替え動作の説明図である。

# 20 発明を実施するための最良の形態

#### 1. 関連技術

25

なお、本実施の形態は、一例として、並列分散リアルタイム制御用Responsive Multi-Threaded (RMT) Processorの中央演算装置上でコンテキストキャッシュとして利用されている。そこで、まず、本実施の形態が関連するCPUを有するコンピュータについて説明する。

図 1 に、一般的な C P U を含むコンピュータの構成図を示す。 このコンピュータは、 C P U 1 O、メモリ 2 O、 I / O 3 O、バス 4 O

20

25

を有する。CPU10は、バス40を介して、メモリ20、I/O30等と接続されている。CPU10は、レジスタファイル1、命令フェッチユニット2、命令キャッシュ3、演算論理ユニット(arithmeticlogic unit、ALU)4、メモリアクセスユニット5、データ キャッシュ6、バスインタフェースユニット7、演算バス11を備える。レジスタファイル1は、汎用レジスタ(GPR)、浮動小数点レジスタ(FPR)、プログラムカウンタ(PC)、ステータスレジスタ(SR)等の各種レジスタを含む。レジスタファイル1は、現在実行中のコンテキストを記憶する。命令キャッシュ3及びデータキャッシュ6は、例えば、SRAM、フリップフロップ(FF)等の素子が用いられ、アクセス、読み出し、書き込み等の処理速度が速いものの記憶容量が小さい。一方、CPU10外部のメモリ20は、SDRAM、DRAM等の素子が用いられ、アクセス、読み出し、書き込み等の処理速度がキャッシュより遅いものの記憶容量が大きい。

ALU4は、局所性原理に従い、命令キャッシュ3、データキャッシュ6又はメモリ20から必要なデータ及び命令を利用する。ALU4は、命令キャッシュ3又はデータキャッシュ6に処理に必要な命令又はデータがあればそれを利用し、なければメモリ20にアクセスして必要な命令又はデータを得る。また、バスインターフェースユニット7は、命令キャッシュ3、メモリアクセスユニット5、データキャッシュ6とCPU外部のメモリ20、I/O30等をバス40を介して接続し、CPU内部と外部の間でデータの入出力行うユニットである。演算バス11は、レジスタファイル1、ALU4、メモリアクセスユニット5を並列に接続する演算パイプライン等のバスである。

命令フェッチユニット2は、命令キャッシュ3へアドレス(Address)を出力し、命令キャッシュ3から命令(instruction)をフェッチし、デコードする。デコードされた命令に従い、ALU4がレジスタファイル1から必要なオペランドを読み出す。ALU4は、それに従い各種演算を行い、演算結果をレジスタファイル1に書き戻す。ロード(Load)又はストア(Store)等のメモリアクセス命令の場合、デコードされた命令に従い、メモリアクセスユニット5がオペランドを読み出す。

メモリアクセスユニット5は、データキャッシュ6にアクセスしLoad又はStoreを行う。Store命令の場合、メモリアクセスユニット5は、アドレスとデータをデータキャ

25

ッシュ6に送り、データをデータキャッシュ6に格納する。Load命令の場合、メモリアクセスユニット5は、アドレスをデータキャッシュ6に送りデータキャッシュ6からデータを読み出す。読み出したデータは、レジスタファイル1に書き戻される。このとき、データキャッシュ6に求めるデータがなければ、メモリ20からそれを読み出す。

このような一般的な構成の場合、レジスタファイル1に記憶されたコンテキストの 退避はStore命令を用いて行う。

図2に、一般的なCPUでのコンテキストスイッチのフローチャートを示す。

OS等のソフトウェアはStore命令を発行し、コンテキストスイッチを開始する。S tore命令が発行されると、レジスタファイル1からデータが読み出され、メモリアクセスユニット5に送られる。そして、メモリアクセスユニット5は、データを格納するアドレスを計算し、データキャッシュ6にアクセスする(S101)。もし、データキャッシュミスが発生した場合(S103)、データキャッシュ6はメモリ20からキャッシュラインを読み込む(S105)。一方、データキャッシュミスが発生しなかった場合(S103)は、ステップS107へ進む。データキャッシュ6は、メモリアクセスユニット5から送られてきたデータを適当なアドレスで自身のキャッシュ内に格納する(S107)。OS等のソフトウェアは、このStore命令の処理を退避すべきレジスタの数だけ繰り返す。すなわち、全てのレジスタの内容の保存が完了していない場合は、ステップS101へ戻り処理を続け、全てのレジスタの内容の保存が完了した場合は、ステップS101へ戻り処理を続け、全てのレジスタの内容の保存が完了した場合は、ステップS111へ進む(S109)。

つぎに、OS等のソフトウェアは、新しく実行されるコンテキストの復帰を、Load 命令を用いて行う。実行中のコンテキストの保存が完了すると、OS等のソフトウェアは、Load命令を発行する。Load命令が発行されると、メモリアクセスユニット5は、データを読み込むためのアドレスを計算し、データキャッシュ6をアクセスする(S111)。もし、データキャッシュミスが発生した場合(S113)、データキャッシュミスが発生した場合(S113)、データキャッシュミスが発生しなかった場合(S113)は、ステップS117へ進む。メモリアクセスユニット5は、データキャッシュ6からデータが返ってくる(S117)と、それをレジスタファイル1に書き戻す。このLoad命令を復帰すべきレジスタの数だけ繰り返す。すなわち、

全てのレジスタ内容の読み込みが完了した場合は、ステップS111へ戻り処理を続け、全てのレジスタ内容の読み込みが完了した場合は、コンテキストスイッチを終了する(S119)。

#### 5 2. コンテキスト切り替え装置を備えたCPU

図3に、コンテキストキャッシュを用いたCPUを含むコンピュータの構成図を示す。

このCPU100は、レジスタファイル1、命令フェッチュニット2、命令キャッシュ3、ALU4、メモリアクセスユニット5、データキャッシュ6、バスインターフェースユニット7、コンテキストキャッシュ8、スレッド制御ユニット9、演算バス11、コンテキスト専用バス12を備える。演算バス11は、レジスタファイル1、ALU4、メモリアクセスユニット5にさらにスレッド制御ユニット9を並列に接続する演算パイプライン等のバスである。図1のCPU10の各部に対応して、同符号で示される各部の構成及び動作は、上述した通りである。

コンテキストキャッシュ8は、SRAM、FF等の素子が用いられ、アクセス、読み 15 出し、書き込み等の処理速度が速い。コンテキストキャッシュ8は、レジスタファイ ル1にコンテキストスイッチ専用バス12により接続され、コンテキストをキャッシュ するために用いられる。スレッド制御ユニット8は、コンテキストキャッシュ8を制御 するためのユニットであり、ALU4やメモリアクセスユニット5と並列に接続されて いる。なお、スレッドとは、一般に、OSがあるプロセス又はタスクを並列処理する 20 ため、プロセス又はタスクを分割した処理単位又は最小単位のことをいう。この際、 プロセス又はタスクが分割されることなく、1 プロセス又は 1 タスクが 1 スレッドとな る場合もある。コンテキストスイッチが起こった場合には、現在実行されているス レッドのコンテキスト(汎用レジスタ、浮動小数点レジスタ、プログラムカウンタ、ス テータスレジスタ等)を退避し、新しく実行されるスレッドのコンテキストを復帰する 25 必要がある。本実施の形態によるコンテキストキャッシュ8を用いたコンテキストス イッチの場合、コンテキストの退避と復帰は、レジスタファイル1とコンテキストキャ ッシュ8のデータをコンテキストスイッチ専用バス12を経て入れ替えるスワップ(S wap)命令を用いる。

10

20

図4に、コンテキストキャッシュを用いたCPUでのコンテキストスイッチのフロー チャートを示す。

OS等のソフトウェアは、Swap命令を発行し、コンテキストスイッチが開始する。 Swap命令は、入れ替えるスレッドIDと共にスレッド制御ユニット9に発行される (S2O1)。スレッドIDは、コンテキストキャッシュ8に格納されているスレッドを一意 に識別するために用いる。スレッド制御ユニット9は、コンテキストスイッチ専用バス12を経て、レジスタファイル1からコンテキストキャッシュ8へデータを退避する と同時並列に、コンテキストキャッシュ8からレジスタファイル1へ新しいスレッドのデータを送る。スレッド制御ユニット9は、送られてきたスレッドIDに基づいて自動的に必要な数だけレジスタファイル1内のデータとコンテキストキャッシュ8内のデータを入れ替える(S2O3)。このように、OS等のソフトウェアはSwap命令を発行するだけで、専用ハードウェアがコンテキストスイッチを開始し終了する。

#### 3. コンテキスト切り替え装置の詳細

15 図5に、コンテキスト切り替え装置の詳細構成図を示す。

レジスタファイル1は、汎用レジスタ111、浮動小数点レジスタ112、プログラムカウンタ113、ステータスレジスタ114を有する。コンテキストキャッシュ8は、コンテキストを格納するコンテキスト記憶領域8-1、8-2、・・・、8-nを所定のコンテキスト数有する。スレッド制御ユニット9は、オンチップのコンテキストキャッシュ8とレジスタファイル1を制御するためのコントローラである。スレッド制御ユニット9内部にはオンチップメモリに格納されているコンテキストを識別するためのスレッドIDを所定数保持するためのスレッドIDテーブル91を設ける。また、マルチスレッドプロセッサの場合は、レジスタファイル1が並列に複数存在することになる。

図6に、Swap命令のフローチャートを示す。

25 コンテキストの切り替えは、例えばコンテキストスイッチハンドラー内でコンテキストスイッチ専用命令を用いることができる。OS等のソフトウェアが、Swap命令を発行すると、専用ハードウェアであるスレッド制御ユニット9が、そのSwap命令とスレッドIDを受けとる(S300)。スレッド制御ユニット9は、スレッドIDに基づいてスレッドIDテーブル91を検索し、コンテキストキャッシュ8をアクセスするため、入

れ替えるべきスレッドのデータ(コンテキスト)が格納されているアドレスを計算し、 また、レジスタファイル1をアクセスするため、レジスタIDを計算する(S301)。つ ぎに、全てのコンテキストのデータ(汎用レジスタ、ステータスレジスタなど)に対し て、ステップS302からS304により繰返しループ処理が行われる。スレッド制御 ユニット9は、計算したアドレスをもとにコンテキストキャッシュ8をアクセスし、新し 5 く入れ替えるスレッドのデータ(コンテキスト)を読み出し、レジスタファイル1にそ れを書き込む(S303)。それと同時又は並列に、スレッド制御ユニット9は、レジ スタファイル1にアクセスし、今実行されているスレッドのデータ(コンテキスト)を 読み出し、コンテキストキャッシュ8にそれを書き込む(S303)。このようにして、レ ジスタファイル1とコンテキストキャッシュ8は、それぞれのデータを入れ替える。全 10 てのデータの入れ替えが終了していない場合(S304)、スレッド制御ユニット9は、 コンテキストキャッシュ8をアクセスするアドレスとレジスタファイル1をアクセスする レジスタIDを1つずつ増やし、ステップS303に戻って処理を続ける(ステップS30 2及びS304による繰返しループ処理)。全てのデータの入れ替えが終了した場 合(S304)、Swap命令を終了する。 15

このように、スレッド制御ユニット9は、コンテキストキャッシュ8とレジスタファイル1のそれぞれのアドレスを連続的にインクリメントすることにより、必要な数だけデータを入れ替える。この際、従来のようにLoad及びStore命令を用いた場合には数百~干数百クロックサイクルかかっていたコンテキストスイッチを、本実施の形態では、レジスタファイル1とコンテキストキャッシュ8のコンテキストスイッチ専用バス12によるデータ転送幅をレジスタのビット幅に比べて非常に広くすることによって、1クロックサイクル〜数クロックサイクル程度で実現する。具体的には、複数個のレジスタをまとめて1つの巨大なレジスタとして、その巨大なレジスタ毎に前記レジスタIDを割り当てるようにする。この際、全てのレジスタをまとめて1つの巨大なレジスタとした場合、1クロックサイクルでコンテキストスイッチを実現できる。

スレッド制御ユニット9は、コンテキストを入れ替えるSwap命令の他に、コンテキストを退避するバックアップ(Backup)命令、コンテキストを復帰するリストア(Restore)命令を処理する。Backup命令の場合は、コンテキストキャッシュ8か

10

. 15

20

25

らレジスタファイル1へのコンテキストのデータ転送は行われず、レジスタファイル 1からコンテキストキャッシュ8へのコンテキストのデータ転送のみが実行される。 一方、Restore命令の場合は逆にレジスタファイル1からコンテキストキャッシュ8 へのコンテキストのデータ転送は行われず、コンテキストキャッシュ8からレジスタファイル1へのコンテキストのデータ転送のみが実行される。

つぎに、図7に、コンテキスト切り替え装置の実装に関する説明図を示す。

コンテキストキャッシュ8は、コンテキストをバックアップするオンチップのメモリであり、この例では2ポートを有し、CPUにオンチップで実装されている。この例では、コンテキストキャッシュ8は、書き込みポート82、読み出しポート83を備える。コンテキストキャッシュ8は、所定の複数コンテキスト分(例えば、32個等)の記憶領域を含むことができる。

レジスタファイル1は、通常のリードポートとライトポートの他にコンテキスト切り替え用の専用ポート、即ちコンテキストスイッチ用読み出しポート17とコンテキストスイッチ用書き込みポート18を付加し、これらのポートにコンテキストを保持するための記憶装置を接続する。この例では、レジスタファイル1は、レジスタ読み出しポート15、レジスタ書き込みポート16、コンテキストスイッチ用読み出しポート17、コンテキストスイッチ用書き込みポート18を備える。レジスタ読み出しポート15は、レジスタファイル1からCPU内の装置へのレジスタの読み出しを、レジスタ書き込みポート16は、CPU内の装置からレジスタファイル1へのレジスタの書き込みを、コンテキストスイッチ用読み出しポート17は、レジスタファイル1からコンテキストファイル8へのレジスタの読み出しを、コンテキストスイッチ用書き込みポート18は、コンテキストファイル8からレジスタファイル1へのレジスタの書き込みを、それぞれ行うポートである。

コンテキストの切り替えが発生した場合、OS等のソフトウェアはSwap命令を発行し、スレッド制御ユニットが、これらのポート17、18を通して中央演算装置のコンテキストキャッシュ8内のデータをレジスタファイル1に保持し、新しいコンテキストをこのレジスタファイル1から取り出す。また、レジスタファイル1とコンテキストキャッシュ8を接続するコンテキスト専用バス12-1、12-2の幅をレジスタファイル1のビット幅より広くすることにより、1度に入れ替えるデータの量を増やす。こ

の例では、レジスタファイル1とオンチップメモリのコンテキストキャッシュ8とは、256ビットのコンテキストスイッチ専用バス12-1、12-2で繋がれる。また、コンテキストキャッシュ8として2ポートのオンチップメモリを用いることにより読み込みと書き出しを同時に行うことができる。そのため32ビット、32本の汎用レジスタは4クロックサイクルでコンテキストを入れ替えることができる。

なお、ビット数、記憶容量、ポート数等の各種パラメータは一例に過ぎず、適宜 設定することができる。

#### 4. その他

5

10 本発明のコンテキスト切り替え方法又はコンテキスト切り替え装置・システムは、その各手順をコンピュータに実行させるためのコンテキスト切り替えプログラム、コンテキスト切り替えプログラムを記録したコンピュータ読み取り可能な記録媒体、コンテキスト切り替えプログラムを含みコンピュータの内部メモリにロード可能なプログラム製品、そのプログラムを含むサーバ等のコンピュータ、等により提供されることができる。

# 産業上の利用可能性

本発明によると、以上のように、特に、リアルタイムOSなどコンテキストの切り替えが頻繁に発生するアプリケーションにおいて、コンテキストの切り替え(コンテ20 キストスイッチ)によるオーバーヘッドを大幅に削減することができる。また、本発明によると、例えば、コンテキストを切り替える度に、コンテキストの保存と読み込みのためのメモリアクセスが、1サイクルから数サイクルで可能とするコンテキスト切り替え方法及び装置、中央演算装置、コンテキスト切り替えプログラムを記録したコンピュータ読み取り可能な記録媒体を提供することができる。

25 また、本発明によると、特に、実時間処理システムのようにコンテキストスイッチ が頻繁に起こるシステムにおいて、コンテキストスイッチにかかる時間を一定とし、 実時間性の時間粒度を非常に小さくすることができる。

# 請求の範囲

1. 複数のコンテキストを切り替えるコンテキスト切り替え装置であって、

演算論理ユニット又はメモリアクセスユニットで実行すべきスレッドに関する コンテキストが記憶されたレジスタファイルと、

が記レジスタファイルに接続され、コンテキストをキャッシュするためのコンテキストキャッシュと、

前記レジスタファイルと前記コンテキストキャッシュを接続するコンテキストスイッチ専用バスと、

前記コンテキストキャッシュに記憶されているスレッドのコンテキストを識別するためのスレッド識別子(スレッドID)を記憶するスレッドIDテーブルを有し、演算論理ユニット及びメモリアクセスユニットと並列に接続され、前記コンテキストキャッシュと前記レジスタファイルとの間のデータ伝送を制御するスレッド制御ユニットと

を備え、

20

25

15 前記スレッド制御ユニットは、

コンテキストの切り替えが発生した場合、入力された切り替え命令と新たに入れ替えるスレッド識別子(スレッドID)に基づき前記スレッドIDテーブルを検索し、

新たに入れ替えるコンテキストが記憶されている前記コンテキストキャッシュ のアドレスと、実行中のコンテキストが記憶されている前記レジスタファイルの レジスタ識別子を求め、

求めたアドレスに基付き前記コンテキストキャッシュをアクセスし、且つ、求めたレジスタ識別子に基付き前記レジスタファイルをアクセスし、前記レジスタファイル及び/又は前記コンテキストキャッシュのコンテキストを前記コンテキストスイッチ専用バスを介して入れ替え、退避又は復帰を実行する前記コンテキスト切り替え装置。

2. 前記コンテキストスイッチ専用バスは、バス幅をレジスタ長以上とすることで、 1度に複数のコンテキストのデータを同時にスワップ、バックアップ又はリストア する請求項1に記載のコンテキスト切り替え装置。

3. 前記コンテキストキャッシュは、リードポートとライトポートを備え、 前記レジスタファイルは、リードポートとライトポート、コンテキストスイッチ用 リードポートとライトポートを備え、

前記コンテキストキャッシュのリードポートとライトポートは、それぞれ前記コンテキストスイッチ専用バスにより前記レジスタファイルのコンテキストスイッチ用ライトポートとリードポートと接続されることを特徴とする請求項1に記載のコンテキスト切り替え装置。

10

5

- 4. 前記スレッド制御ユニットは、コンテキストキャッシュにキャッシュされた所定数のコンテキストを識別する所定数のスレッドIDテーブルを含むことを特徴とする請求項1に記載のコンテキスト切り替え装置。
- 5. 前記スレッド制御ユニットは、コンテキストを入れ替えるスワップ命令を実行する場合、オペレーティングシステム等のソフトウェアからスレッド識別子(スレッドID)をオペランドとして含むスワップ命令が発行されると、前記レジスタファイルから前記コンテキストキャッシュへ実行中のスレッドのコンテキストを退避すると同時に、前記コンテキストキャッシュから前記レジスタファイルへ新しく入れ替えるスレッドのコンテキストを送り、自動的に必要な数だけ前記レジスタファイル内のデータと前記コンテキストキャッシュ内のデータを入れ替えることを特徴とする請求項1乃至4のいずれかに記載のコンテキスト切り替え装置。
- 6. 前記スレッド制御ユニットは、コンテキストを退避するバックアップ命令を実行する場合、オペレーティングシステム等のソフトウェアからスレッド識別子(スレッドID)をオペランドとして含むバックアップ命令が発行されると、前記レジスタファイルから前記コンテキストキャッシュへのコンテキストのデータ転送を行い、前記コンテキストキャッシュから前記レジスタファイルへのコンテキストのデータ転送は行わないことを特徴とする請求項1乃至4のいずれかに記載のコンテキ

スト切り替え装置。

7. 前記スレッド制御ユニットは、コンテキストを復帰するリストア命令を処理する場合、オペレーティングシステム等のソフトウェアからスレッド識別子(スレッドID)をオペランドとして含むリストア命令が発行されると、前記コンテキストキャッシュから前記レジスタファイルへのコンテキストのデータ転送を行い、前記レジスタファイルから前記コンテキストキャッシュへのコンテキストのデータ転送は行わないことを特徴とする請求項1乃至4のいずれかに記載のコンテキスト切り替え装置。

10

5

8. 前記請求項1乃至7のいずれかに記載のコンテキスト切り替え装置と、 命令及びデータをそれぞれキャッシュする命令キャッシュ及びデータキャッシュと、

前記命令キャッシュから命令をフェッチ及びデコードする命令フェッチユニット 15 と、

レジスタファイルに記憶された命令に従い各種演算を行い、演算結果を前記 レジスタファイルに書き戻す演算論理ユニットと、

前記レジスタファイルからオペランドと命令が送られ、前記データキャッシュ をアクセスし、ロード又はストアを実行するメモリアクセスユニットと、

- 20 前記レジスタファイル、前記演算論理ユニット、前記メモリアクセスユニット及び前記スレッド制御ユニットを並列に接続する演算バスと、 を備えた中央演算装置。
- 9. 前記メモリアクセスユニットは、ストア命令の場合はアドレスとデータを前記 データキャッシュに送り、データを前記データキャッシュに格納し、ロード命令の場合はアドレスを前記データキャッシュに送り、データを前記データキャッシュ から読み出し、読み出したデータを前記レジスタファイルに書き戻す請求項8に記載の中央演算装置。

15

20

25

10. 演算論理ユニット又はメモリアクセスユニットで実行すべきスレッドに関する コンテキストが記憶されたレジスタファイルと、

前記レジスタファイルに接続され、コンテキストをキャッシュするためのコンテキストキャッシュと、

5 前記レジスタファイルと前記コンテキストキャッシュを接続するコンテキスト スイッチ専用バスと

> を備えたコンテキスト切り替え装置を用い、複数のコンテキストを切り替える コンテキスト切り替え方法であって、

コンテキストの切り替えが発生した場合、入力された切り替え命令と新たに入れ替えるスレッド識別子(スレッドID)に基付き、前記コンテキストキャッシュに記憶されているスレッドのコンテキストを識別するためのスレッド識別子(スレッドID)を記憶する前記スレッドIDテーブルを検索し、

新たに入れ替えるコンテキストが記憶されている前記コンテキストキャッシュのアドレスと、実行中のコンテキストが記憶されている前記レジスタファイルのレジスタ識別子を求め、

求めたアドレスに基付き前記コンテキストキャッシュをアクセスし、且つ、求めたレジスタ識別子に基付き前記レジスタファイルをアクセスし、前記レジスタファイル及び/又は前記コンテキストキャッシュのコンテキストを前記コンテキストスイッチ専用バスを介して入れ替え、退避又は復帰を実行する前記コンテキスト切り替え方法。

11. コンテキストを入れ替えるスワップ命令を実行する場合、オペレーティングシステム等のソフトウェアからスレッド識別子(スレッドID)をオペランドとして含むスワップ命令が発行されると、前記レジスタファイルから前記コンテキストキャッシュへ実行中のスレッドのコンテキストを退避すると同時に、前記コンテキストキャッシュから前記レジスタファイルへ新しく入れ替えるスレッドのコンテキストを送り、自動的に必要な数だけ前記レジスタファイル内のデータと前記コンテキストキャッシュ内のデータを入れ替えることを特徴とする請求項10に記載のコンテキスト切り替え方法。

- 12. コンテキストを退避するバックアップ命令を実行する場合、オペレーティングシステム等のソフトウェアからスレッド識別子(スレッドID)をオペランドとして含むバックアップ命令が発行されると、前記レジスタファイルから前記コンテキストキャッシュへのコンテキストのデータ転送を行い、前記コンテキストキャッシュから前記レジスタファイルへのコンテキストのデータ転送は行わないことを特徴とする請求項10に記載のコンテキスト切り替え方法。
- 13. コンテキストを復帰するリストア命令を処理する場合、オペレーティングシステム等のソフトウェアからスレッド識別子(スレッドID)をオペランドとして含むリストア命令が発行されると、前記コンテキストキャッシュから前記レジスタファイルへのコンテキストのデータ転送を行い、前記レジスタファイルから前記コンテキストキャッシュへのコンテキストのデータ転送は行わないことを特徴とする請求項10に記載のコンテキスト切り替え方法。

25

5

14. 演算論理ユニット又はメモリアクセスユニットで実行すべきスレッドに関する コンテキストが記憶されたレジスタファイルと

前記レジスタファイルに接続され、コンテキストをキャッシュするためのコン テキストキャッシュと、

20 前記レジスタファイルと前記コンテキストキャッシュを接続するコンテキスト 専用バスと

を備えたコンテキスト切り替え装置を用い、コンピュータが複数のコンテキストを切り替えるコンテキスト切り替えプログラムであって、

コンテキストの切り替えが発生した場合、入力された切り替え命令と新たに入れ替えるスレッド識別子(スレッドID)に基付き、前記コンテキストキャッシュに格納されているスレッドのコンテキストを識別するためのスレッド識別子(スレッドID)を記憶する前記スレッドIDテーブルを検索するステップと、

新たに入れ替えるコンテキストが記憶されている前記コンテキストキャッシュのアドレスと、実行中のコンテキストが記憶されている前記レジスタファイ

20

ルのレジスタ識別子を求めるステップと、

求めたアドレスに基付き前記コンテキストキャッシュをアクセスし、且つ、求めたレジスタ識別子に基付き前記レジスタファイルをアクセスし、前記レジスタファイル及び/又は前記コンテキストキャッシュのコンテキストを前記コンテキストスイッチ専用バスを介して入れ替え、退避又は復帰を実行するステップと

をコンピュータに実行させるためのコンテキスト切り替えプログラム。

15. 演算論理ユニット又はメモリアクセスユニットで実行すべきスレッドに関する 10 コンテキストが記憶されたレジスタファイルと、

> 前記レジスタファイルに接続され、コンテキストをキャッシュするためのコン テキストキャッシュと、

> 前記レジスタファイルと前記コンテキストキャッシュを接続するコンテキスト スイッチ専用バスと

15 を備えたコンテキスト切り替え装置を用い、コンピュータが複数のコンテキストを切り替えるコンテキスト切り替えプログラムを記録したコンピュータ読み取り可能な記録媒体であって、

コンテキストの切り替えが発生した場合、入力された切り替え命令と新たに入れ替えるスレッド識別子(スレッドID)に基付き、前記コンテキストキャッシュに格納されているスレッドのコンテキストを識別するためのスレッド識別子(スレッドID)を記憶する前記スレッドIDテーブルを検索するステップと、

新たに入れ替えるコンテキストが記憶されている前記コンテキストキャッシュのアドレスと、実行中のコンテキストが記憶されている前記レジスタファイルのレジスタ識別子を求めるステップと、

25 求めたアドレスに基付き前記コンテキストキャッシュをアクセスし、且つ、求めたレジスタ識別子に基付き前記レジスタファイルをアクセスし、前記レジスタファイル及び/又は前記コンテキストキャッシュのコンテキストを前記コンテキストスイッチ専用バスを介して入れ替え、退避又は復帰を実行するステップと

をコンピュータに実行させるためのコンテキスト切り替えプログラムを記録したコンピュータ読み取り可能な記録媒体。



図 1

#### 2/8



図2

WO 2004/063925





図 4

5/8



図 5



図6





## INTERNATIONAL SEARCH REPORT

International application No. PCT/JP03/15838

| A. CLAS                                                                                                                       | SIFICATION OF SUBJECT MATTER                                                                    |                                                                                           |                            |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|----------------------------|--|--|--|--|
| Int                                                                                                                           | .C1 <sup>7</sup> G06F9/46                                                                       |                                                                                           |                            |  |  |  |  |
| ·                                                                                                                             |                                                                                                 |                                                                                           |                            |  |  |  |  |
| According to International Patent Classification (IDC)                                                                        |                                                                                                 |                                                                                           |                            |  |  |  |  |
| According to International Patent Classification (IPC) or to both national classification and IPC                             |                                                                                                 |                                                                                           |                            |  |  |  |  |
|                                                                                                                               | OS SEARCHED                                                                                     |                                                                                           |                            |  |  |  |  |
| Int                                                                                                                           | locumentation searched (classification system followed Cl <sup>7</sup> G06F9/46-9/54            | d by classification symbols)                                                              |                            |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
| Documentation searched other than minimum documentation to the extent that such documents are included in the fields searched |                                                                                                 |                                                                                           |                            |  |  |  |  |
| OTCS                                                                                                                          | rigo 21TT 1911 VOID 1257-1266                                                                   | Jitsuyo Shinan Toroku Koh                                                                 | o 1996–2004                |  |  |  |  |
|                                                                                                                               | i Jitsuyo Shinan Koho 1971-2004                                                                 | 7 2                                                                                       | -                          |  |  |  |  |
| Electronic o                                                                                                                  | lata base consulted during the international search (na                                         | me of data base and, where practicable, sea                                               | arch terms used)           |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           | ,                          |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
| C Pocti                                                                                                                       |                                                                                                 |                                                                                           |                            |  |  |  |  |
|                                                                                                                               | MENTS CONSIDERED TO BE RELEVANT                                                                 |                                                                                           |                            |  |  |  |  |
| Category*                                                                                                                     | Citation of document, with indication, where                                                    | appropriate, of the relevant passages                                                     | Relevant to claim No.      |  |  |  |  |
| Y                                                                                                                             | Guangzuo, C. et al., Paralle                                                                    | el Replacement                                                                            | 1-15                       |  |  |  |  |
|                                                                                                                               | Mechanism for MultiThread, A                                                                    | dvances in Parallel                                                                       |                            |  |  |  |  |
|                                                                                                                               | and Distributed Computing 19 1997, pages 338 to 334; part                                       | 97 Proceedings,                                                                           |                            |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
| Y                                                                                                                             | Wills, D.S. et al., Pica: An                                                                    | Ultra-Light Processor                                                                     | 1-15                       |  |  |  |  |
|                                                                                                                               | for High-Throughput Applicat                                                                    | ion, Computer Design:                                                                     |                            |  |  |  |  |
|                                                                                                                               | VLSI in Computers and Proces<br>Proceedings, 1993, pages 410                                    | to 414: particularly                                                                      |                            |  |  |  |  |
| ľ                                                                                                                             | pages 411 to 412                                                                                | co 414, particularly,                                                                     |                            |  |  |  |  |
| A                                                                                                                             | Kunk H of all pector                                                                            |                                                                                           |                            |  |  |  |  |
| - î                                                                                                                           | Kwak, H. et al., Effects of multithreading on cache performance, Computers, IEEE Transactions   |                                                                                           |                            |  |  |  |  |
|                                                                                                                               | on, 1999, pages 176 to 184                                                                      | , IDDB ITAIISACCIONS                                                                      |                            |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
| × Furthe                                                                                                                      | er documents are listed in the continuation of Box C.                                           | See patent family annex.                                                                  |                            |  |  |  |  |
|                                                                                                                               | categories of cited documents:                                                                  |                                                                                           |                            |  |  |  |  |
| "A" docume                                                                                                                    | nt defining the general state of the art which is not                                           | "T" later document published after the inter<br>priority date and not in conflict with th | e application but cited to |  |  |  |  |
| 'E" earlier d                                                                                                                 | ed to be of particular relevance<br>locument but published on or after the international filing | "X" understand the principle or theory under document of particular relevance; the c      | rlying the invention       |  |  |  |  |
| date                                                                                                                          | nt which may throw doubts on priority claim(s) or which is                                      | considered novel or cannot be considered                                                  | ed to involve an inventive |  |  |  |  |
| Cited to                                                                                                                      | establish the publication date of another citation or other                                     | "Y" step when the document is taken alone document of particular relevance; the c         | laimed invention cannot be |  |  |  |  |
| 'O" docume                                                                                                                    | reason (as specified) nt referring to an oral disclosure, use, exhibition or other              | considered to involve an inventive step combined with one or more other such              | when the document is       |  |  |  |  |
| means                                                                                                                         | nt published prior to the international filing date but later                                   | combination being obvious to a person                                                     | skilled in the art         |  |  |  |  |
| tnan the priority date claimed                                                                                                |                                                                                                 |                                                                                           |                            |  |  |  |  |
| ate of the ac                                                                                                                 | ctual completion of the international search anuary, 2004 (23.01.04)                            | Date of mailing of the international searc                                                | h report                   |  |  |  |  |
| 23 January, 2004 (23.01.04) 03 February, 2004 (03.02.04)                                                                      |                                                                                                 |                                                                                           |                            |  |  |  |  |
| Jame and e-                                                                                                                   | iling address of the 1947                                                                       |                                                                                           |                            |  |  |  |  |
| Name and mailing address of the ISA/ Japanese Patent Office                                                                   |                                                                                                 | Authorized officer                                                                        |                            |  |  |  |  |
|                                                                                                                               |                                                                                                 |                                                                                           |                            |  |  |  |  |
| acsimile No                                                                                                                   |                                                                                                 | Telephone No.                                                                             |                            |  |  |  |  |
| orm PCT/ISA/210 (second sheet) (July 1998)                                                                                    |                                                                                                 |                                                                                           |                            |  |  |  |  |

### INTERNATIONAL SEARCH REPORT

International application No. PCT/JP03/15838

| Category* | Citation of document, with indication, where appropriate, of the relevant passages                                                                | Relevant to claim No. |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--|
| A .       | JP 2000-242505 A (Mitsubishi Electric Corp.),<br>08 September, 2000 (08.09.00),<br>Par. Nos. [0044] to [0047]<br>(Family: none)                   | 1-15                  |  |
| Y         | JP 3-9431 A (NEC Corp.),<br>17 January, 1991 (17.01.91),<br>Full text<br>(Family: none)                                                           | 12-13                 |  |
| A .       | JP 10-11301 A (Seiji IMAI),<br>16 January, 1998 (16.01.98),<br>Full text<br>(Family: none)                                                        | 1-15                  |  |
| A         | JP 2000-76079 A (NEC Corp.), 14 March, 2000 (14.03.00), Full text (Family: none)                                                                  | 1-15                  |  |
| A .       | JP 2002-513182 A (Infineon Technologies North America Corp.), 08 May, 2002 (08.05.02), Full text & WO 99/56209 A1 & EP 1073956 A1 & US 6378065 B1 | 1-15                  |  |
|           |                                                                                                                                                   |                       |  |
|           |                                                                                                                                                   |                       |  |

|               |                                                                    | - BWENNER O ICI/ JF03/                | 19838 .          |  |  |
|---------------|--------------------------------------------------------------------|---------------------------------------|------------------|--|--|
| A. 発明の        | 属する分野の分類(国際特許分類(IPC))                                              |                                       |                  |  |  |
|               | Int. Cl <sup>7</sup> GO6F 9/46                                     |                                       |                  |  |  |
| B. 調査を        | <u></u><br>行った分野                                                   |                                       |                  |  |  |
|               | 最小限資料(国際特許分類(IPC))                                                 | ·                                     |                  |  |  |
| ·             | Int. Cl' G06F 9/46                                                 |                                       |                  |  |  |
|               | 1111. C1 G06F 9/46                                                 | - 9/54                                | •                |  |  |
| 最小限資料以        | 外の資料で調査を行った分野に含まれるもの                                               |                                       |                  |  |  |
| 日本国第          | <b>ミ用新案公報 1922-1996年</b>                                           |                                       |                  |  |  |
| 日本国公          | 、開実用新案公報 1971-2004年<br>第四新案登録公報 1900-2004年                         | •                                     |                  |  |  |
| " ~           | 用新案登録公報 1996-2004年<br>登録実用新案公報 1994-2004年                          |                                       |                  |  |  |
|               |                                                                    |                                       |                  |  |  |
|               | 用した電子データベース(データベースの名称                                              | 「、 調査に使用した用語)                         |                  |  |  |
| •             |                                                                    |                                       |                  |  |  |
| C. 関連す        | Z la 문지 나 는 la Y shath                                             | · · · · · · · · · · · · · · · · · · · |                  |  |  |
| <u>し</u> 関連する | ると認められる文献<br>                                                      |                                       | F                |  |  |
| カテゴリー*        | 引用文献名 及び一部の箇所が関連する                                                 | ときは、その関連する筋所の表示                       | 関連する<br>請求の範囲の番号 |  |  |
| Y             | Guangzuo, C. et al., Parallel Re                                   |                                       | 1-15             |  |  |
|               | MultiThread, Advances in Parall                                    | el and Distributed                    | 1-15             |  |  |
|               | Computing, 1997 Proceedings, 1                                     | 9 9 7, pp. 338-334,                   |                  |  |  |
| 1             | 特に、p. 340の記載                                                       |                                       |                  |  |  |
| Y             | Wills DS of all Divers A VIII                                      | • • • • =                             |                  |  |  |
| •             | Wills, D.S. et al., Pica: An Ult                                   | ra-Light Processor for                | 1 - 15           |  |  |
|               | High-Throughput Application, Co<br>Computers and Processors, 1993. | mputer Design: VLSI in                | -                |  |  |
|               | 1993, pp. 410-414, 特に、pp.                                          | 411-412                               |                  |  |  |
| •             | , 11 , ,,,,,,,,,,,,,,,,,,,,,,,,                                    | 411 412                               |                  |  |  |
|               | S J. S. Hellih J. T. T. D. C. L. S.                                |                                       |                  |  |  |
|               | だにも文献が列挙されている。<br>                                                 | □ パテントファミリーに関する別                      | 紙を参照。            |  |  |
| * 引用文献の       | クカテゴリー                                                             | の日の後に公表された文献                          |                  |  |  |
| もの            | 望のある文献ではなく、一般的技術水準を示す                                              |                                       | れた文献であって         |  |  |
| 「E」国際出願       | 日前の出願または特許であるが、国際出願日                                               | 出願と矛盾するものではなく、発<br>の理解のために引用するもの      | 明の原理又は理論         |  |  |
| 以後に公          | 念表されたもの                                                            | 「X」特に関連のある文献であって、当                    | 該文献のみで発明         |  |  |
| 日若しく          | 張に疑義を提起する文献又は他の文献の発行<br>は他の特別な理由を確立するために引用する                       | の新規性又は進歩性がないと考え                       | られるもの            |  |  |
| 文献(理          | !由を付す)                                                             | 「Y」特に関連のある文献であって、当<br>上の文献との、当業者にとって自 | 豚文献と他の1以         |  |  |
| 「D」日頭によ       | る開示、使用、展示等に言及する文献                                                  | よって進歩性がないと考えられる                       | もの               |  |  |
|               | 日前で、かつ優先権の主張の基礎となる出願                                               | 「&」同一パテントファミリー文献                      |                  |  |  |
| 国際調査を完了       | 国際調査を完了した日国際調査報告の発送日                                               |                                       |                  |  |  |
|               | 23.01.04                                                           | 03. 2. 2                              | YUU4             |  |  |
| 国際調査機関の       | 名称及びあて先                                                            | 特許庁審査官(権限のある職員)                       | 5B 9646          |  |  |
|               | 特許庁 (ISA/JP)<br>便番号100-8915                                        | 殿川 雅也。江                               | 32 30 30         |  |  |
| 東京都           | 千代田区霞が関三丁目4番3号                                                     | 電話番号 03-3581-1101                     | <b>唐籍 2525</b>   |  |  |
|               |                                                                    |                                       | 内線 3585          |  |  |

| C (続き).<br>引用文献の | - San                                                                                       |               |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|--|
| カテゴリー*           | 一                                                                                                                               | 関連する 請求の範囲の番号 |  |  |  |
| A                | Kwak, H. et al., Effects of multithreading on cache performance, Computers, IEEE Transactions on, 1 9 9 9, pp. 176-184          | 1-15          |  |  |  |
| A                | JP 2000-242505 A (三菱電機株式会社) 200<br>0.09.08,段落番号0044-0047 (ファミリーなし)                                                              | 1-15          |  |  |  |
| Y                | JP 3-9431 A (日本電気株式会社)<br>1991. 01. 17,全文 (ファミリーなし)                                                                             | 12-13         |  |  |  |
| A                | JP 10-11301 A (今井正治) 1998. 01. 16,<br>全文 (ファミリーなし)                                                                              | 1-15          |  |  |  |
| A                | JP 2000-76079 A (日本電気株式会社) 2000.<br>03.14,全文 (ファミリーなし)                                                                          | 1-15          |  |  |  |
| A                | JP 2002-513182 A (インフィニオン テクノロジーズ ノース アメリカ コーポレーション)<br>2002.05.08,全文<br>& WO 99/56209 A1<br>& EP 1073956 A1<br>& US 6378065 B1 | 1-15          |  |  |  |
|                  |                                                                                                                                 |               |  |  |  |
|                  |                                                                                                                                 |               |  |  |  |
|                  |                                                                                                                                 |               |  |  |  |
|                  |                                                                                                                                 |               |  |  |  |